## In The Name Of God

Project Title: MIPS Pipeline Processor with Java

Professor: Dr. Mousavi

July 5<sup>th</sup> 2018 - 4<sup>th</sup> Semester - Shiraz University

This project was started on July 1  $^{\rm st}$  2018 and ended on July 5  $^{\rm th}$  2018 by 8 hours/Day coding .

The uploaded file is consisted of multiple backups which were taken at each stage that the program was developed. each backup directory has it's own RegisterFile, DataFile and TestCase which is suitable for a special aspect added in the following stage of developing.

The total scheme of project is based on the picture below(figure 1.):



The start of this project was with this scheme(figure 2):



I started from figure 2, step by step, and finally got to figure 1.

## The last update has this abilities:

- 1. It supports all "  $R\_Type$  " instructions such as : add , sub , and , or , slt , xor , nor
- 2. It supports all I\_Type instructions such as: lw, sw, beq
- 3. It also supports Jump instruction.
- 4. It can detect hazards and solve it by forwarding.

We can compile and run pipeline instructions by two ways:

- 1. Left to right
- 2. Right to left

If we start the pipeline from left to right, we shall execute the stages as below:

Fetch -> decode -> execute -> memory -> write back

But if we start the pipeline from right to left, we shall execute the stages as below:

Write back -> memory -> execute -> decode -> fetch

The difference is that in the first method we may only face Control Hazards but in the second

method we will only face Data Hazards due to the reference:

five stages as they complete execution. Returning to our laundry analogy, clothes get cleaner, drier, and more organized as they move through the line, and they never move backward.

There are, however, two exceptions to this left-to-right flow of instructions:

- The write-back stage, which places the result back into the register file in the middle of the datapath
- The selection of the next value of the PC, choosing between the incremented PC and the branch address from the MEM stage

Data flowing from right to left does not affect the current instruction; these reverse data movements influence only later instructions in the pipeline. Note that

the first right-to-left flow of data can lead to data hazards and the second leads to control hazards.

The method used in this project is right to left method which fixes the need of stalling.

## My Notes While Coding:

```
(5/8/14)
add
                         herzand
    7/1000 / 2 -5
Sir
     7/7/0/7-31
                          ha tand
SIT
add 1, 2, 3
      41516
add
      71817
     10/19(1)
     (2/20 (13)
21+ 14, 15, 1631 (4-1)
     (7, 1819 12 17 -> 4
```







